#include<stdio.h>

void order(int a[],int n){
	int i=0,kg=0,t,j;
	for(i=0;i<n-1;i++){
		kg=1;
		for(j=0;j<n-1-i;j++){
			if(a[j]<a[j+1]){
				t=a[j];
				a[j]=a[j+1];
				a[j+1]=t;
				kg=0;
			}
		}
		if(kg==1) break;
	}
}

int main()
{
	int m,flag,sign,n[20][20],num[42]={0},i=0;
	scanf("%d",&m);
	for(sign=0;sign<m;sign++)
	{
		for(flag=0;flag<m;flag++)
		{
			scanf("%d",&n[sign][flag]);
			num[i]+=n[sign][flag];
		}
		i++;
	}
	for(sign=0;sign<m;sign++)
	{
		for(flag=0;flag<m;flag++)
		{
			num[i]+=n[flag][sign];
		}
		i++;
	}
	for(sign=0,flag=0;sign<m;sign++,flag++)
	{
		num[i]+=n[sign][flag];
	}
	i++;
	for(sign=0,flag=m-1;sign<m;sign++,flag--)
	{
		num[i]+=n[sign][flag];
	}
	order(num,i+1);
	for(sign=0;sign<=i;sign++)
	{
		printf("%d",num[sign]);
		if(sign<i) printf(" ");
	}
	return 0;
}
